<template>
  <div class="Word">
    <!-- 此div用来加载PageOffice客户端控件，其中div的高宽及位置就决定了控件的大小及位置 -->
    <div style="width:auto; height:900px;" v-html="poHtmlCode"></div>
  </div>
</template>

<script>
import request from '@/utils/request'
export default {
  data() {
    return {
      poHtmlCode: '',
      open_params: '',
    }
  },
  created: function () {
    //使用pageofficectrl.WindowParams获取获取父页面(此项目中为：HomeView.vue)中POBrowser.openWindow()方法的第三个参数的值,获取到的值为string类型
    this.open_params = JSON.parse(pageofficectrl.WindowParams);
    this.openFile().then(response => {
      this.poHtmlCode = response;
    });
  },
  methods: {
    OnPageOfficeCtrlInit() {
      //PageOffice的初始化事件回调函数，您可以在这里添加自定义按钮
      pageofficectrl.AddCustomToolButton("保存", "Save", 1);//其中"Save"对应methods中的Save()函数，并且需要在mounted中挂载。
      pageofficectrl.AddCustomToolButton("另存为", "SaveAs", 12);
      pageofficectrl.AddCustomToolButton("页面设置", "PrintSet", 0);
      pageofficectrl.AddCustomToolButton("打印", "PrintFile", 6);
      pageofficectrl.AddCustomToolButton("全屏/还原", "IsFullScreen", 4);
      pageofficectrl.AddCustomToolButton("-", "", 0);
      pageofficectrl.AddCustomToolButton("关闭", "Close", 21);
    },
    AfterDocumentOpened() {
      //在这里写您文档打开后自动触发的代码
    },
    Save() {
      //使用SaveFilePage属性设置后端保存方法的Controller路由地址，这个地址必须从"/"开始，并且也可以向此路由地址传递json字符串参数，示例如下：
      let saveFileUrl = "/SimpleWord/save";
      let paramValue = new URLSearchParams(this.open_params);//为了简单起见，这里直接使用打开时的参数。
      pageofficectrl.SaveFilePage = `${saveFileUrl}?${paramValue.toString()}`;
      //在这里写您保存前的代码
      pageofficectrl.WebSave();
      //在这里写您保存后的代码，比如判断保存结果pageofficectrl.CustomSaveResult
      if("ok"==pageofficectrl.CustomSaveResult){
        alert("保存成功！");
      }else{
        alert("保存失败！");
      }
    },
    SaveAs() {
      pageofficectrl.ShowDialog(3);
    },
    PrintSet() {
      pageofficectrl.ShowDialog(5);
    },
    PrintFile() {
      pageofficectrl.ShowDialog(4);
    },
    Close() {
      pageofficectrl.CloseWindow();
    },
    IsFullScreen() {
      pageofficectrl.FullScreen =
        !pageofficectrl.FullScreen;
    },
    openFile() {
      //发起GET请求到后端Controller的/SimpleWord/Word路由
      return request({
        url: '/SimpleWord/Word',
        method: 'get',
        params: this.open_params
      })
    }
  },
  mounted: function () {
    //将当前页面methods中定义的函数挂载到PageOffice控件，例如控件触发的事件、自定义按钮触发的函数。
    window.POPageMounted = this;//此行必须
  }
}
</script>
